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(54) Procede et dispositif pour la generation de nombres pseudo-aleatoires uniques. 

fef) Le procede consiste a inscrire (1, 2) dans une zone 
aSterminee de la memoire non volatile d'une carte a me- \ 
moire a microcircuit une information de valeur determinee 
et non repetitive a chaque generation d'un nombre alea- 
toire et a convertir (3, 4) cette information en une informa- 
tion ayant la forme d'un nombre pseudo-aleatoire en pro- 
grammant I'unite de traitement au moyen d'un programme 
de cryptage de I'information standard, type DES. 
Applications: cartes a memoire. 
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PRO CEDE ET DISPOSITIF POUR LA GENERATION 
DE NOMBRES P S EUDO - ALE ATO IRE S UNIQUES 

La presente invention concerne un precede et un 
dispositif pour la generation de nombres 
pseudo-aleatoires uniques. 

Elle s 1 applique notaimtient a la realisation de 
cartes a microcircuits dites a puces utilisables dans 
tout systeme ou l'acces a des informations ou a des 
services est severement controle. II s T agit notamment 
des systemes distributeurs de monnaie fiduciaire, du 
domaine des systemes de television a peage ; des 
systemes pour la distribution d' essence ou de fuel 
domestique ; des systemes pour l'acces aux banques de 
donnees etc. . . 

Dans les cartes a memoire a microprocesseur qui 
sont utilisees dans les domaines precedents, 1 1 acces a 
des informations ou a des services est severement 
controle. On utilise pour cela des mots de passe. Ces 
mots de passe sont de plus en plus souvent transmis en 
les cryptant par un code pseudo-aleatoire fourni par un 
generateur a structure programmee ou eventuellement 
cablee. Dans les cartes a memoire a base de 
microprocesseurs , il n'existe dans I'etat de la 
technique que des generateurs roateriels (base sur des 
phenomenes physiques) ou des generateurs logiciels base 
sur des proprietes mathematiques et deja utilises dans 
le monde informatique traditionnel. Ces deux principes 
ne peuvent pas garantir l'unicite des nombres generes ce 
qui presente un inconvenient majeur de securite en 
matiere de cryptograph ie moderne. 

Si cette solution presente l'avantage de ne pas 
renseigner les fraudeurs sur les mots de passe 
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utilises,, elle laisse en effet la possibility a ces 
derniers de recopier les mots de passe cryptes transmis 
qui, de par leur defaut d'unicite, peuvent toujours etre 
reutilises pour donner 1 1 acces aux informations ou 
services pour lesquels la carte est dediee. En effet, 
il suffit alors de renouveler l 1 experience de mardere a 
retrouver une valeur deja utilisee et ainsi frauder le 
systeme . 

Par ailleurs, la production de nombre aleatoire 
unique se heurte aux possibilites technologiques de 
reecriture dans des memoires non volatiles. Chaque 
cellule ne peut en effet etre reecrite plus de 10.000 
fois. Le but de 1" invention est de pallier les 
inconvenients precites. 

A cet effet, l« invention a pour objet un precede 
pour la generation de nombres pseudo-aleatoires uniques 
dans une carte a memo ire a microcircuits comportant au 
moins une memoire non volatile reinscriptible (EEPROM) 
couplee a un organe de traitement de donnees, 
caracterise en ce qu'il consiste 

- a inscrire dans une zone determinee de la 
memoire, une information de valeur determinee et non 
repetitive a chaque generation d'un nombre aleatoire et, 

- a convertir cette information en une information 
ayant la forme d'un nombre pseudo-aleatoire en lui 
faisant subir dans 1' organe de traitement de donnees un 
programme de cryptage de type DES . 

Elle a egalement pour objet un dispositif pour la 
mis en oeuvre du procede. 

L 1 invention a en outre pour principal avantage de 
permettre, en utilisant un compteur qui comporte un 
regis tre a decalage, d'obtenir un nombre de tirages tres 
eleve de nombres aleatoires comparativement au nombre de 
cycles d'ef f acement/ecriture autorises dans la memoire 
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non volatile equipant habifcuellement les cartes a 
memoire. Ainsi, malgre un nombre d *ef f acement/ecriture 
limite a 10.000 par la technologie actuelle des memoires 
non volatiles, encore connues sous la designation 
EEPROM, il est possible, grace a I 1 invention, de generer 
dans le pire des cas 320.000 valeurs differentes et dans 
le meilleur des cas 21 milliards, en utilisant un espace 
memoire EEPROM tres reduit de 64 bits. 

D"autres. caracteristiques et avantages de 
1* invention apparaitront ci-apres a l'aide de la 
description qui suit faite en regard des dessins annexes 
qui representent : 

Figure 1 : un mode d 1 execution du procede selon 
1 1 invention mis sous la forme d'un or ganigr amine . 

Figure 2 : un format d'un mot d 1 information 
utilisable pour la mise en oeuvre du procede selon 
!• invention represents par 1 •organigramme de la 
figure 1. 

Dans sa definition la plus generale, une carte a 
memoire pour 1 ' application du procede selon 1' invention 
comporte, de facon connue et non representee, un 
dispositif de memorisation et un organe de traitement 
forme normalement par un microprocesseur ou tout 
dispositif equivalent, couples l'un a 1 1 autre par un bus 
de donnees et d'adresses. Ce bus assure egaleroent la 
liaison du microcireuit de la carte ainsi forraee, avec 
des dispositif s d'ecriture et de lecture exterieurs a la 
carte. Le dispositif de memorisation comporte 
generalement une memoire non volatile, de type EPROM ou 
EEPROM, dans laquelle sont enregistres des 
microprogrammes necessaires au f onctionnement de 
l 1 organe de traitement et normalement une memoire vive 
volatile de type RAM. Cette demiere sert pour la 
memorisation temporaire des donnees et des instructions 
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specif iques de 1 1 application en cours avec ia carte a 
memoire. Dans la memoire non volatile sont ranges, par 
exemple, d'une part le code secret identifiant le 
titulaire de la carte, avec eventuellement un programme 
5 de chif frement pour l'obtention d'une signature calculee 
sur la base du code secret et, d 1 autre part, des 
instructions du programme d 1 utilisation lui-meme. 

Le procede selon 1 ' invention dont les etapes la 4 
sont representees schematiquement sur 1 1 organigramrae de 

10 la figure 1 consiste, chague fois qu'un nombre aleatoire 
10 est a produire, a calculer suivant les etapes 1 et 2 , 
a partir d'une donnee 1 d 1 information determinee (de 
longueur N = 64 bits par exemple) , une nouvelle donnee 2 
de meme longueur N, mais dont la valeur ne pourra plus a 

15 nouveau etre generee lors d'une requete ulterieure de 
nouvelle donnee 2. Une fois transformee, la donnee 2 est 
a I'etape 4 associee a une clef secrete 3 comportant un 
meme nombre de bits, par un algorithme de calcul 
communement connu sous 1 1 abreviation anglo-saxonne DES 

2 0 de "Data Encryption Standard" et dont une description 

peut etre trouvee dans les brochures des normes FIPS des 
"Federal Information Processing Standards" des 
Etats-Unis d 1 Amer ique . 

La superiority de l 1 algorithme d 1 association DES 
25 sur les autres algorithmes d 1 association est qu r il 
permet d'obtenir pour chaque clef secrete constante 3 de 
longueur de N bits, les 2 N combinaisons possibles du 
resultat en garantissant tou jours le caractere non 
previsible du nombre aleatoire 10, c 1 est-a-dire , 

3 0 d'obtenir tou jours des nombres aleatoires differents 10, 

Ceci est obtenu a partir des 2 N combinaisons possibles 
de la donnee en entree. Mais le fait que la cle ait une 
longueur de N bits n'a rien a voir avec le fait qu'il y 
ait 2 N combinaisons differentes sur le resultat, Ceci 
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est lie au fait que la donnee en entree a une longueur 
de N bits. Par exemple, les caracteristiques de DES 
indiquent que pour une clef secrete constante, les 2^4 
combinaisons possibles de la donnee balaient les 2 64 
5 combinaisons possibles du resultat ce qui garantit, en 
plus du caractere non previsible du nombre aleatoire 
(lie aux performances de DES) , la propriete de tou jours 
obtenir des nombres aleatoires differents. Dans 
1' invention, on. disposera ainsi d'une clef secrete 

10 constante 3 . 

Pour obtenir ce resultat , chaque donnee 2 
d 1 information variable est structuree de la facon qui 
est representee a la figure 2. Son format comporte trois 
zones, une premiere zone 5 de capacite egale par exemple 

15 a 16 bits represente les etats pris par un premier 
compteur, une deuxieme zone 6 de capacite egale par 
exemple a 32 bits represente les etats d f un registre a 
decalage et, une trois ieme zone 7 de capacite egale par 
exemple a 16 bits represente les etats d'un deuxieme 

2 0 compteur. Les premiere et deuxieme zones 5 et 6 sont 
alors situees dans une memoire non volatile de la carte 
alors que la zone 7 est situee en memoire vive. Selon 
1" invention, le contenu des trois zones est considere 
comme equivalent a celui qui serait donne par un 

2 5 compteur de N bits qui serait increments a chaque 

demande de calcul. Cette information est done previsible 
mais est tou jours differente des valeurs precSdentes. Le 
stockage en memoire EEPROM des donnees des zones 5 et 6 
permet de conserver les valeurs de leur contenu lorsque 

3 0 la tension d 1 alimentation de la carte est supprimee. 

Cette solution permet d 1 obtenir un nombre maximum de 
nombres aleatoires tres superieur aux 10.000 autorises 
par la technologie EEPROM . 

La zone 6, qui est organisee en registre & 
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decalage, permet d'obtenir un nombre maximum de nombre 
aleatoires. Pour cela, £ chaque nouveau calcul ou 
session, un bit de valeur 1 est charge a la derniere 
position de poids le plus faible du registre qui est 
5 encore a 0. Lorsque 3 2 demandes de calcul, correspondant 
a la mise a 1 des 3 2 bits du registre 6 a decalage, sont 
effectuees, le calcul suivant remet a zero le registre a 
decalage represents par la zone 6. Lorsque les 32 
calculs ont ete realises, le registre a decalage est a 

10 la valeur FFFFFFFFH bien que chaque bit n'ait ete ecrit 
qu'une seule fois. On obtient ainsi 32 valeurs 
differentes en ne consommant qu f une seule ecriture pour 
chaque cellule. A chaque effacement de ce registre de 32 
bits, le compteur de 16 bits de la zone 5 en EEPROM sera 

15 increments ce qui en definitive permet d'obtenir, 32 X 
10000 = 320000 valeurs imprevisibles et non repetitives 
pour la donnee 2 (sans qu'aucun des bits manipules en 
EEPROM ne soit efface/ecrit plus de 10000 fois) . Pour 
obtenir une plus grande quantite de valeurs (hors pire 

20 cas) , il suffit d'adjoindre a cette variable de 48 bits 
en EEPROM, un compteur 7 de 16 bits en RAM qui sera 
increments a chaque calcul dans une meme session. 

La zone 7 situee en memoir e RAM permet done 
d 1 augmenter le nombre des valeurs precedentes en 

2 5 augmentant, de maniere similaire au compteur materialise 

par la zone 5, le contenu du compteur materialise par la 
zone 7 a chaque nouveau calcul dans une meme session. 
S'il arrive dans une meme session que ce compteur 
deborde, e'est-a-dire que son contenu depasse ici 65536 

3 0 valeurs, on peut modifier le contenu du registre a 

decalage materialise par la zone 6 de la memoire EEPROM 
comme si une nouvelle session commencait. Dans ce cas, 
on met a 1 un autre des bits de ce registre 6. 

Au total, cette disposition permet en concatenant, 
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c ' est-a-dire en juxtaposant les 48 bits en EEPROM aux 16 
bits situes en memoire RAM, d'obtenir 320,000 X 65536 
soit environ 21 milliards de valeurs imprevisibles et 
non repetitives par la mise en oeuvre d'un calcul de 
5 nombres aleatoires en utilisant 1 1 algor ithme DES 
precedemment cite. 

Par securite, on associe au compteur 5 de 16 bits 
en EEPROM un compteur- image en EEPROM. Ce compteur-image 
contient tou jours la meme valeur que le veritable 

10 compteur et est utilise dans le cas ou la^ valeur du 
compteur est detruite (arrachage de la carte lorsque le 
compteur vient d'etre efface pour en modifier la 
valeur) . II n'est pas necessaire de prevoir la meme 
chose pour le registre a decalage car celui-ci n 1 est 

15 efface que pour sa remise a zero. 

La structure du compteur ainsi utilisee (comprenant 
un registre a decalage) permet d'obtenir un nombre de 
tirages tres eleve comparativement au nombre de cycles 
d ' ef f acement/ecriture (mise a jour) autorise dans la 

2o memoire non volatile. Ainsi 7 malgre un nombre 
d 1 eff acement/ecriture limite a 10000 par la technologie 
EEPROM, on arrive a generer dans le pire des cas 3 20.000 
valeurs differentes et dans le meilleur des cas 21 
milliards . 
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REVENDIC. TIONS 



1. Precede pour la generation de nombres 
pseudo-aleatoires uniques dans une carte a memoire a 
microcircuits comportant au moins une memoire non 
volatile reinscriptible (EEPROM) couplee a un organe de 

5 traitement de donnees caracterise en ce qu'il consiste, 

- a inscrire (1,2) dans une zone determinee de la 
memoire, une information de valeur determinee et non 
repetitive a chaque generation d'un nombre aleatoire et, 

- a convert ir (3,4) cette information en une 
10 information ayant la forme d'un nombre pseudo-aleatoire 

en lui faisant subir dans l 1 organe de traitement de 
donnees un programme de cryptage de type DES * 

2. Procede selon la revendication 1, caracterise en 
ce que 1 ■ information de valeur determinee et non 

15 repetitive est inscrite dans une memoire EEPROM de la 
carte - 

3. Precede selon la revendication 2, caracterise en 
ce que 1 1 information de valeur determinee et non 
repetitive est structuree suivant au moins deux zones, 

2 0 une premiere zone (6) pour ecrire de facon systematique 
au moins un nouveau bit chaque fois qu'un nombre 
pseudo-aleatoire est genere par la carte, et une 
deuxieme zone (5) de comptage pour totaliser le nombre 
de fois ou la premiere zone a ete totalement ecrite. 

25 4. Procede selon la revendication 3, caracterise en 

ce qu'il consiste a structurer 1 ' information de valeur 
determinee et non repetitive en lui rajoutant une 
troisieme zone (7) de comptage pour totaliser le nombre 
de fois ou, dans une meme session, un nombre 

30 pseudo-aleatoire a ete genere. 
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5. Procede selon la revendication 4, caracterise en 
ce que les premiere et deuxieme zones (6, 5) sont 
memorisees dans une memoire non volatile de la carte et 
en ce que la troisieme zone (7) est memorisee dans une 
memoire volatile de la carte. 

6. Procede selon la revendication 3, caracterise en 
ce qu'on reserve une troisieme zone pour servir d 1 image 
du resultat du comptage totalise dans la deuxieme zone. 

7 . Dispositif pour la mise en oeuvre du procede 
selon I'une quelconque des revendications la 6, 
caracterise en ce qu'il est forme par une carte a 
microcircuit coraportant une unit£ de traitement couplee 
a une memoire non volatile et a une memoire volatile. 



2672402 



1/1 

FIG-1 



DONNEE 64 BITS 



□ 



CLE SECRETE 64 BITS 



DES ( Donne'e, del : 


- Random de 64 bits 























► 


NOMBRE ALEATOIRE 64BITS 







V 



10 

INFORMATION VARIABLE 64 BITS 
(previsible mais non repetitive, 
y compris d'une session a I'autre) 
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